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METHOD AND APPARATUS FOR PROCESSING DATA 

Field of the Invention 

The present invention relates to systems and methods for processing data, and in 
particular, to systems and methods for processing data in parallel. 

Background of the Invention 

5 Since the inception of the electronic computer, much consideration has been given to 

processing data in parallel in order to speed up processing and reduce user wait time for results. 
Reduction of user wait time can be important for: querying a database in real-time, as in a license 
plate search; servicing multiple transactions at the same time, as in financial transactions; or 
producing complex images rapidly, as in medical imaging systems in which calculation and 
10 presentation of the desired image may have to be done as quickly as possible. 

Early attempts at implementing parallel processing focused on analyzing a proposed 
algorithm for recursive structure and distributing the instruction execution of those recursive 
regions across a number of processors. While this method is fairly successful, it lacks flexibility 
and efficient scalability. ' 

15 For example, in many cases the system architect was required to know in advance the 

number of processors necessary to effectively execute the algorithm. If the algorithm changed, 
the number of processors required for effective execution also changed. Because addition of 
processors in response to each software change was generally difficult and cumbersome, systems 
were typically provided with many processors in order to ensure the system could be used if the 

20 algorithm changed. This, of course, had the drawback of being prohibitively expensive. 

Further, the addition of processors did not result in a linear increase in processing power 
because of overhead required to coordinate the processors. Thus, if the number of processors in 
a system were doubled, the speed of the system usually did not double because of communication 
and synchronization overhead. 
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Therefore, a need exists for parallel processing schemes that can be efficiently and 
inexpensively scaled. The present invention provides the aforementioned desirable characteristics 
while avoiding the undesirable characteristics of prior art devices. 

Summary of the Invention 

5 The invention relates to a system and method for processing data. The system has one or 

more gateway processors, and one or more processing engines which communicate with the 
gateway processors. In some embodiments of the system, it is desirable to have a controller 
processor, which communicate with both the gateway processors and the processing engines. In 
a typical embodiment of the system, one or more spooler processors are provided which 

10 communicate with the gateway processors, the controller processors and the processing engines. 
In another embodiment of the system that allows external control of the system, a client processor 
is provided which communicates with the gateway processors. One feature of the invention is 
that the gateway processors, the controller processors, the processing engines and the spooler 
processors, if provided, communicate with each other by exchanging messages. This allows the 

15 system of the present invention to be distributed across a network of machines or reside in the 
memory of a single machine. The system can, therefore, be scaled simply by adding additional 
processors or machines to the network. 

A gateway processor is responsible for receiving a transaction from one of the client 
processors, distributing data to the controller processors in response to the client transaction, and 
20 responding to the client transaction. In other embodiments, the gateway processor may also 
distribute data to the processing engines or the spooler engines in response to the client 
transaction. 

The above mentioned objects (the gateway processor, the controller processor, the 
spooler processor, and the processing engine) as described above are functional groupings of 
25 responsibilities and tasks that are distributed in the prescribed manner to maximize the flexibility 
and performance of the system. In the current implementations of the system these particular 
functional groupings are used to build a commercially applicable data processing system from the 
system components. It is an important feature of the system that groupings such as these can be 
created and distributed in any manner to most effectively utilize the underlying physical 
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componentry of the system. This is made possible by the system's ability to decompose larger . 
tasks into smaller idempotent distributable and parallelizable sub tasks. 

Brief Description of the Drawings 

This invention is pointed out with particularity in the appended claims. The above and 
5 further advantages of this invention may be better understood by referring to the following 
description taken in conjunction with the accompanying drawings, in which: 

Fig. 1 A is a diagrammatic view of an embodiment of a data processing system of the 
present invention servicing a single client transaction; 

Fig. IB is a diagrammatic view of an embodiment of a data processing system of the 
10 present invention servicing multiple client transactions; 

Fig. 2 is a diagrammatic view of an embodiment of a data processing system of the present 
invention servicing a transaction in which there is a conflict for a particular processing engine; and 

Fig. 3 is a diagrammatic view of an embodiment of a processor of the present invention. 

Detailed Description of the Invention 

15 In overview, the data processing system of the present invention includes at least one 

gateway processor 12, at least one controller processor 14, and at least one processing engine 16. 
If output is desired from the system, then at least one spooler processor 18 may be provided. 
Additionally, a client processor 1 0 may be provided to facilitate communication between user 
applications and gateway processors 12. Generally, any number of processors may be used in any 

20 configuration. For example, FIG. 1 A shows an embodiment of a data processing system including 
a client processor 10, a gateway processor 12, a controller processor 14, a processing engine 16, 
and a spooler processor 18. FIG. IB shows an embodiment of a data processing system including 
two client processors, generally 1 0, four gateway processors, generally 1 2, two controller 
processors, generally 14, four processing engines, generally 16, and three spooler processors, 

25 generally 18. The various processors of the systems shown in FIGS. 1A and IB may be 

implemented in hardware, may be implemented as software processes resident in the memory of a 
single computer, or may be implemented as software processes which are distributed among a 
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network of computers. For ease of reference throughout the specification, the generic term 
"processor" will be used when referring to the various processors of the system. However, it 
should be understood that use of the term "processor" encompasses hardware processors as well 
as software processes. 

5 If the processors are distributed over a network of computers, the processors may 

communicate by way of a communication line which may be: a proprietary data bus; a standard 
data bus, such as SCSI, NUBUS, ISA, PCI, HP PI, or EISA; or a network protocol such as 
TCP/IP, Ethernet, or FDDI. In a preferred embodiment, each processor is implemented in 
software resident on a personal computer which is networked to other personal computers which 
10 host the other processors included in the system. 

The various processors communicate with each other through messages. The messages 
can have any format which allows for unambiguous communication between processors. In a 
currently preferred embodiment, messages sent between processors must begin with a four-byte 
length field. This field indicates the length of the message being sent. The length field may be 

15 followed by a four-byte transaction code, which is a unique identification code specifying the type 
of work required of the receiving processor in order to respond to the message. The transaction 
code is followed by the message. The message can include any information associated with the 
message or it can be data. Typically, there is enough information contained in the message for the 
system's communications layer to transparently support replication and system pairing capacities, 

20 without the explicit knowledge of higher level applications. The message passing is optimized to 
perform only those transmissions that are needed. For example, many transmissions are simply 
broadcast without the need for establishing a session connection or receipt verification. The 
system as a whole uses the message layer as a central nervous system, tying together and 
synchronizing what are often thousands of separate subtasks that form a single request from a 

25 client. 

The Client Processor 

A client processor 1 0, if provided, is responsible for accepting requests from a user 
application, formatting those user application requests into messages suitable for transmission 
over the communication line that interconnects the processors of the system, and transmitting the 
30 request message to the gateway processor 12. The client processor 10 may be an integral part of 
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a user application. Alternately, the client processor may be provided as a separate entity that 
interfaces with multiple user applications. Currently preferred is providing the client processor 1 0 
as a dynamically linked library which can be used concurrently by various user applications. This 
dynamically linked library format is currently used to provide non-proprietary interfaces to the 
system, by supporting facilities such as ODBC and X/Open. 

The client processor 10 may be able to format messages suitable for transmission using 
various communication line protocols in order to act as a rudimentary form of bridge between 
processors connected by different communication lines. However, currently preferred is a client 
processor 1 0 that formats user application requests suitable for transmission using only one 
communication line protocol. 

The client processor often acts as a translation layer, converting host specific data to and 
from the system's native storage formats. Additionally, the client may perform various sorts of 
validations of application inputs, and even extends new features to support a wider range of 
clients. The client processor, like the other processing engines, has full access to the functional 
operations primitives of the system. The client processor in some implementations, therefore, is 
able to perform a substantial duty in the form of off-loading processing overhead from the objects 
that comprise the central system, enhancing the system's scalability. 

Once the user application request message is properly formatted for transmission, the 
client processor 10 selects a gateway processor 12 to which it transmits its request. Selection of 
the gateway processor 12 can be done in any number of ways. It is better, for the sake of 
efficiency, that user application requests are fairly evenly distributed among gateway processors 
12. One way of achieving such "load leveling" is that a client processor 10 may, before 
transmitting a request, determine the "loading", i.e., the activity level, of any particular gateway 
processor 12 before transmitting its request. Alternately, each client processor 10 may maintain 
an ordered list of gateway processors 12 which it 

transmits requests to in round-robin order. Currently preferred, however, is for each client 
processor 10 to maintain a list specifying a primary gateway processor 12 and a list of alternate 
gateway processors 12. The client processor 10 of the preferred embodiment transmits requests 
to its primary gateway processor 12, and only transmits requests to the alternate gateway 
processors 12 when its primary gateway processor 12 is non-responsive. 
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A user application request message may include a request for output; for example, a user, 
application request may be a database query that also includes a request for report output The 
request for output will contain additional information that may be extremely detailed; for example, 
the report requested by the user may specify the width of the report columns, the font to be used, 
5 etc. At the very least, however, the client processor's output request includes the identity of the 
spooler processor 1 8 which should service the output request. The client processor 1 0 may select 
the identity of the desired spooler processor 18 in any number of ways. In general, however, a 
spooler processor 18 is selected based on the type of output device it controls. For example, the 
client processor 10 may inquire of all the spooler processors 18, at the time of the user application 

10 request, what type of output device the respective spooler processor 1 8 is controlling The client 
processor 10 would then use the returned information to select the identity of the desired spooler 
processor 1 8. Currently preferred, however, is for the client processor 10 to make this inquiry at 
system start-up time and store the returned information in a list, which it accesses when it formats 
the user application request. As an alternative to the above routine, the client may also request 

15 the return of its query in a raw data format, which may be gathered and returned by a spooler or 
gateway processor as may be appropriate. 

The Gateway Processor 

A gateway processor 12 is responsible for receiving user application requests and 
distributing work to other processors in the system in order to service those user application 

20 requests. A gateway processor 12 receives user application request messages, whether sent by a 
client processor 10 or sent directly from a user application. Although it is contemplated that a 
gateway processor 12 may receive incoming user application request messages from random 
client processors 10, it is currently preferred that each gateway processor 12 is assigned to one or 
more client processors as a primary gateway processor 12 and to one or more client processors as 

25 an alternate gateway processor 12. Thus, in the currently preferred embodiment, a single gateway 
processor 12 may receive user application request messages from more than one client processor 
10, but only if multiple client processors 10 have included gateway processor 12 in their list of 
primary and alternate gateway processors to which requests may be sent. 

When a user application request received, the gateway processor 12 assigns a unique 
30 session identifier to the user application making the request. Thus, user applications capable of 
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making multiple simultaneous requests will be assigned multiple, unique session identifiers 
associated with each individual request. Once a session identifier is assigned, the gateway 
processor 12 transmits that session identifier to the user application making the request. Any 
mechanism for ensuring the session identifier is unique may be used. For example, a list 
5 containing all active session identifiers may be stored in memory that must be checked by all 
gateway processors 12 before assigning a session identifier. Alternately, each gateway processor 
12 could be required to maintain a table of assigned session identifiers, the table being shared with 
all other gateway processors 12. Currently preferred, however, is assigning a set of session 
identifiers to each gateway processor 12 which only that particular gateway processor 12 can 
10 assign. 

Session identifiers for the currently preferred embodiment may be formed in any fashion, 
so long as each gateway processor 12 does not form or assign session identifiers outside of the 
range assigned to it. In the currently preferred embodiment, a gateway processor 12 multiplies its 
own identification number, which is stored in its memory, by a predetermined constant, which is 
15 generally equal to the maximum number of session identifiers each gateway processor 12 is 
allowed to assign. The gateway processor 12 then increments an integer variable. The integer 
variable is added to the product described above unless incrementing it caused it to equal the 
predetermined constant, in which case is set to zero before it is added to the product. 

Each gateway processor 12 maintains a list of active session identifiers which it has 
20 already assigned to user application requests. Once the gateway processor 12 has formed a 

session identifier, it compares the session identifier against its list of active session identifiers. If 
the formed session identifier does not appear in the list, it is assigned. However, if the session 
identifier so formed does appear in the list, a new session identifier must be formed. In order to 
form a new session identifier, the gateway processor 12 repeats the calculation described above 
25 and checks the new session identifier against its list of active session identifiers. This process 
repeats until a session identifier is formed which does not appear in the list of active session 
identifiers maintained by the gateway processor 12. 

For example, in order to form a unique session identifier, "Gateway Processor 0" would 
multiply its own identification number, in this case 0, by a predetermined constant. An integer, 
30 e.g. 2, is then added to the product. This results in a session identifier of two for the present 
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example. The gateway processor 12, in this case "Gateway 0," then checks its list of active 
session identifiers to determine if "2" is present, and therefore active and previously assigned. If 
"2" appears in the list, it signifies that a user application request that has been assigned that 
session identifier is still active. In this case, the gateway processor 12, "Gateway 0," would 

5 increment the integer to three. If the predetermined constant was equal to three, the integer 
would be reset to zero. That is, the integer resets to zero whenever incrementing would cause it 
to exceed the predetermined constant. Assuming the predetermined constant is greater than 
three, the gateway processor 12 adds three to the product of its identification number and the 
predetermined constant, and checks its table of active session identifiers for the resultant session 

10 identifier, in this case "3." This procedure is repeated until a session identifier is formed that does 
not appear in the gateway processor's 12 list of active session identifiers. That session identifier is 
assigned to the user application request and is entered in the list of active session identifiers 
maintained by the gateway processor 12. 

Once a session identifier has been assigned to the user application request, the gateway 
15 processor 12 assigns a unique task identification number to the user application request. Again, 
any method for ensuring the uniqueness of the task identification numbers may be used, although 
preferred is forming the task identification numbers by concatenating the gateway identification 
number, the current date, and the current time. It is evident, therefore, that one session identifier 
may be associated with multiple task identification numbers, i.e. one user application request 
20 identified by a unique session identifier may transmit multiple request messages, each of which 
require a unique task identification number. 

Once a unique task identification number has been assigned to the user application request 
message, the gateway processor 12 enters the task identification number in a list of active task 
identification numbers and transmits the task identification number, the associated session 

25 identifier, and any other information associated with the user application request to a controller 
processor 14. It is contemplated that a gateway processor 12 may be assigned to one controller 
processor 14 to which it transmits data or that the gateway processor 12 could select one of the 
set of controller processors 14 to transmit to based on the controller processor's level of activity. 
Preferred, however, is for the gateway processor 12 to transmit information to a random 

30 controller processor 14, Any method of randomly selecting controller processors 14 may be used. 
In the currently preferred embodiment, each gateway processor 12 maintains a pointer which 
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points to the controller processor 1 4 that should receive the next message. At system start-up - 
time, each gateway processor 12 sets its pointer to point to a controller processor 14 selected at 
random. Thereafter, each time a message is sent to a controller processor 14 by the gateway 
processor 12, the pointer is incremented to indicate that another controller processor 14 should 
5 receive the next message. 

If the user application request message includes requested-output-format information, the 
gateway processor 12 transmits the task identification number and requested-output-format 
information to the spooler processor 1 8 indicated by the client processor 1 0 in the user 
application request message. If the selected spooler processor 1 8 is non-responsive, the gateway 
10 processor 12 transmits a message to the user application indicating that the report cannot be 
started. The user application then makes a decision whether to abort the report request or retry 
the report. 

Once the spooler processor 1 8 has received the task identification number and requested- 
output-format information, the gateway processor 12 sends the user application request message 
15 to a processing engine 16 for processing. Processing engine 16 can be selected in any fashion as 
long as the request is taken by a processing engine 16 which has access to the data specified in the 
user application request message. The gateway processor 12 may broadcast the request to all 
processing engines 16. 

However, it is currently preferred that each gateway processor 12 calculates this 
information for itself in the following manner. Each gateway processor 12 accesses a table 
definition file. The table definition file is created at start-up time and resides in the memory or on 
the disk of the gateway processor 12. The table definition file contains assorted information 
about each table on the system, including a mapping based on a data attribute. For example, in a 
database system, the table would provide a processing engine 16 mapping based on a primary key, 
i.e. a hash table. If the user application request is based on the attribute used for the mapping, the 
gateway processor 12 can use the mapping to determine which processing engines 16 need to be 
accessed. For example, if the user application is requesting a database sort based on the primary 
key contained in the table, the gateway processor 12 uses the hash table to determine which 
processing engines 1 6 have access to the requested data. 
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If, however, the user application requests data that is based on some other attribute of the 
data, the gateway processor 12 must calculate a new mapping using the table already provided 
For example, if a user application requests data based on some other field which is not the primary 
key, the gateway processor 12 must calculate a new hash table using any method known in the art 
5 for generating a hash table with a level of indirection. The new hash table calculated by the 
gateway processor 12 indicates which processing engines 16 have access to the requested data; 
thus, the gateway processor 12 directs the user application request to the proper processing 
engine 16 based on the data affected by the user application request. 

If a processing engine 16 indicated by the above determination is non-responsive, the 
10 gateway processor 12 determines if the user application request is directed to data that is 
redundantly stored. This determination can be done in many ways. Currently preferred is 
providing a one-byte flag in the table definition file. The value of the byte flag indicates whether 
or not the data is stored redundantly, as well as the level of redundancy. 

If the data is stored redundantly, the gateway processor 12 transmits the user application 
15 request to the redundant processing engine 16. If the data is not stored redundantly, or if the 
processing engines 16 indicated as redundant are non-responsive, or if the gateway processor 12 
returns a message to the user application indicating that its request has failed. The user 
application then decides whether to retry its request or abandon it. If the user application retries 
the request, the gateway processor 12 attempts to contact the indicated processing engines 16 
20 again. If the user application aborts the request, the gateway processor 12 transmits a message 
that the request has aborted to any controller processor 14. This may be done because the 
controllers share data with each other. The gateway processor 12 then removes the task 
identification number from its list of active task identification numbers. 

After transmitting the user application request message to the processing engines 16, the 
25 gateway processor 12 waits to receive a message indicating that the processing engine 16 has 
completed the user application request. In cases requiring that multiple processing engines 16 
simultaneously perform an operation, the gateway processor 12 waits until it receives completion 
messages from all processing engines 16 required to perform an operation in response to the user 
application request. While the gateway processor 12 is waiting for completion messages, it 
30 continues to receive and distribute user application request messages from client processors 10. 
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Once all completion messages for a given task are received by the gateway processor 12, it 
transmits a message to the controller processor 14 currently indicated by its pointer. The message 
informs the controller processor 14 that the task associated with the user application request's 
task identification number has been completed. The gateway processor 12 then removes the task 
5 identification number from its list of active task identification numbers. 

The gateway processor, because of its role as an external interface, often forms the root of 
what is defined in the invention as a "chained process". Often, a request made to the gateway is 
complex, and requires input from multiple other processing engines. In such a case, a status block 
associated with the task identification number is maintained. As each task is distributed, an entry 

10 is noted in this status block. As each task responds, often with a message of successful 

completion, failed completion, or a preparation to for final "commit" of a task, a notation is made 
within this status table. This allows for the decomposition of a task into a very large number of 
smaller atomic tasks that can be performed in parallel, yielding a much lower overall task 
completion time. Note that there is no need to monitor each task; instead, the task that notes 

15 each action on the task has the ability to take further action on the task. Further, the task is 
passively monitored for timeout. The chained process is not limited in any way to the gateway 
processor, it simply occurs there more often. As another example, a relational table with a foreign 
key on a processor engine node may need to retrieve a tuple form another processor engine node 
without pausing in its own task; it will therefore spawn a chained task to execute this operation in 

20 parallel. Due to the distributed nature of the system, the chained process forms a central 
methodology for the completion of complex tasks. 

The Controller Processor 

The controller processor 1 4 acts as a central synchronization and redundancy point for the 
data processing system of the present invention. As noted above, when a gateway processor 1 2 

25 receives a user application request message, it assigns a unique task identification number to that 
request. The gateway processor 12 then transmits the task identification number and the 
associated session identifier to the controller processor 14 currently indicated by its pointer. The 
controller processor 14 stores this information in a list containing all active task identification 
numbers and then communicates it to all other controller processors 14 in the system. This may 

30 be done by a broadcast transmission from one controller processor 14 to all other controller 
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processors 14 present in the system or the receiving controller processor 14 may transmit the 
information to all other controller processors 14 individually. Preferred, however, is for one 
controller processor 14 to pass the information along to one other controller processor 14, which 
in turn does the same. Thus, at any one time, all controller processors 14 have a complete list of 
5 all active task identification numbers, the session identifiers with which they are associated, and 
any other associated information such as requested output information. Each controller processor 
14, therefore, has a complete list of all active tasks that must be completed by the system. 

When a user application request is completed or aborted, a controller processor 14 
receives a message from a gateway processor 12 informing it that the task associated with a task 

10 identification number has either completed or aborted. The controller processor 14 relays this 
information to all other controller processors 14 as noted above. If requested output information 
is included in the user application request, the controller processor 14 forwards the request 
completed/request aborted message to the proper spooler processor 18, which is determined by 
the controller processor 14 in the same manner as the gateway processor 12. Preferably, the 

15 controller processor 14 determines the proper spooler processor 1 8 from the user application 
request message sent by the client processor 10. Additionally, each controller processor 14 
maintains a set of system logs. 

At system start-up time, one controller processor 14 is selected as "Controller 0." This 
may be the controller processor 14 that is actually "Controller 0," or, if the controller processor 

20 14 designated as "Controller 0" fails to become active at system start-up time, the controller 
processor 14 having the nest highest rank, i.e. "Controller 1," assumes the duties of "Controller 
0." Each processor is required to "check-in" with "Controller 0" when the processor first starts 
up. This allows "Controller 0" to create a comprehensive map of the system, i.e. the number of 
gateway processors 12, the number of controller processors 14, the number of processing engines 

25 16 and the number of spooler devices 1 8 present. 

In addition, "Controller 0" acts as a sanity check for the other controller processors 14 in 
the system. When "Controller 0" first starts up, it checks its log to determine if the system is 
starting up from a normal shutdown. If a normal shutdown is indicated, "Controller 0" contacts 
every other controller processor 14 in the system to verify that the last time-stamp in the log 
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maintained by "Controller 0" is the most recent time-stamp of any log. If this is true, the system- 
starts up normally. 

If "Controller 0" is unable to verify that its logs have the most recent time-stamp, or if the 
log maintained by "Controller 0" does not indicate a normal system shutdown, "Controller 0" 
5 must contact each controller processor 14 and request task identification numbers that were 
active for time period between the last successfully completed task and the last time-stamp in the 
system. "Controller 0" must check the validity of each of the task identification numbers so 
gathered. If all of the task identification numbers are valid, the system can start up. Otherwise, 
"Controller 0" must identify every invalid transaction and execute a series of transactions to 
10 restore the system to the state it was in before the invalid transaction began processing by 
executing transactions which "undo" the effects of the invalid transactions. 

The Processing Engine 

The processing engine 16 is largely responsible for storing the data present in the system 
and actually doing the calculations requested by the user application request message. Each 

15 processing engine 16 maintains at least a portion of the system's data, and each processing engine 
16 maintains the following logs. A processing engine 16 may maintain the system's data on any 
memory device to which it has access. Thus, a processing engine may maintain the system's data 
on a single hard disk, a redundant disk array, a logical disk (i.e. a stripe of a larger, system-wide 
disk array), a floppy disk, a CD-ROM, an optical disk, random access memory, a tape drive, etc. 

20 In short, the processing engine may maintain system data on any type of memory device. A 
currently preferred method is for the processing engine to store data on "logical drives", which 
consist of several physical storage devices such as those mentioned above, with a suitably large 
cached subset of information maintained in random access memory. The processor stores the 
data in this way transparently to other requesting processes, and this methodology allows it to 

25 realize benefits in parallel throughput from the devices without requiring any specialized hardware 
to do so. Thus, multiple processing engines 16 may be provided that each contain the entirety of 
the data processing system's data. This configuration would allow a high level of fault tolerance 
which is desirable when data must always be available. Alternately, data could be apportioned 
among the various processing engines 16 in order to speed up actions on large amount of data. 

30 Another alternative would be to apportion the data among several processing engines 1 6 and then 
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replicate critical portions of the data in order to provide both speed as well as fault tolerance with 
respect to the redundant portion of data. 

The Spooler Processor 

The spooler processor 18 is responsible for producing output for the data processing 
5 system. A spooler processor 18 controls an output device. The output device controlled by the 
spooler processor 1 8 can be a printer, disk drive, display, or other device for outputting data in 
physical form. Additionally, a client processor 10 can request that the spooler processor 1 8 
return data directly to it. 

A spooler processor 18 is notified when a gateway processor 12 receives a user 

10 application request message that includes requested output information. As noted above, the 
gateway processor 12 sends the task identification number assigned to the user application 
request to the spooler processor 18 along with any requested output information. The spooler 
processor 18 stores the task identification number and the requested output information in a list. 
The spooler processor 1 8 waits until it receives a request completed/request aborted message 

15 from a controller processor 14 indicating that the user application request has finished. If the 

message received by the spooler processor 1 8 is a request aborted message, the spooler processor 
1 8 removes the task identification from its list of reports to generate. If the message is, instead, 
that the user application request has completed, the spooler processor 1 8 requests the processed 
data from all of the processing engines 16. This may be done as a broadcast to all processing 

20 engines 16. Currently preferred, however, is requesting the data from the processing engines in 
round-robin fashion. As the spooler processor 18 receives data from the various processing 
engines 16, the spooler processor 18 formats the data according to the requested output 
information, and sends the formatted data to its associated output device. If the client processor 
1 0 requested that the data be returned directly to the user application, the spooler processor 18 

25 sends a message or messages to the client processor 10 containing the requested data. 

For systems in which more than sixteen processing engines 1 6 are provided, it is currently 
preferred that one leader is selected for each group of sixteen processing engines. Each leader 
requests data from the other 15 processing engines in its group and formats the data for its group. 
The spooler processor 18 requests data from the leaders in round-robin order and does the final 
30 processing required to provide report output. 
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This scheme can also be used in applications in which the additional processing power of 
the processing engines 16 may be effectively used. For example, if the output requested is a sum 
total of various data entries distributed over various processing engines 16, it is preferred that 
each processing engine 16 functioning as a leader sum the data entries of every processing engine 
5 16 in its group of sixteen and pass only the sum to the spooler processor 18. The spooler 
processor 18 then needs only to sum the responses from the "leader" processing engines 16 to 
provide the output requested by the client processor 10. 

System Operation 

Referring to Table 1 and FIGS. 1 A and IB, the data processing system of the present 
10 invention is shown servicing client transactions. A client processor 1 0 sends a request (step 1 02) 
that is received by a gateway processor 12 (step 102). If multiple client processors 10 are 
provided, they may make simultaneous user application requests, as shown in FIG. IB. Requests 
sent by the client processors 1 0 may be database query requests that have associated report 
output requests or they may be simply requests to perform an operation on data. A client 
15 processor 10 can be a user application program that includes the proper mechanism for 

communicating with a gateway processor 12. Alternately, a client processor 10 can be a separate 
program which receives requests from an application program and forwards those requests to the 
gateway processor 12. 

Each gateway processor 12 receiving a user application request assigns a unique session 
20 identifier to the user application request (step 104) and a unique task identification number to the 
specific request made by the client processor 10 (step 106). The gateway processor 12 sends the 
assigned session identifier to the user application (step 108), which then uses the unique session 
identifier to make subsequent, associated requests or check the status of a pending request. The 
gateway processor sends the task identification number to a random controller processor 14 (step 
25 1 10), and enters the session identifier in its list of active session identifiers and the task 

identification number in its list of active task identification numbers. If more than one controller 
processor 14 is provided, as in FIG. IB, the controller processors 14 now share task identification 
information (step 112). 

The client transaction shown in FIGS. 1 A and IB includes a report output request. So, 
30 after the task identification number is sent to the controller processors 14, the gateway processor 
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1 2 sends the task identification number with the report request to a spooler processor 1 8 (step 
] 12). The spooler processor 1 8 to which the report information is sent is selected by the client 
processor 10 on the basis of the type of output device the spooler processor 1 8 controls. 

The gateway processor 12 determines the path necessary to access the data requested by 
5 the user application request and uses that information when accessing the table definition file, 
which was created at system start-up, that indicates which processing engine 16 has responsibility 
for the affected data. If the user application request requires exclusive access to the affected data, 
the gateway processor 12 locks the path to the affected data. The gateway processor 12 then 
sends the query request to the processing engines 16 (step 114). A user application request may 
10 require accessing multiple processing engines 16 or it may require accessing one processing 

engine 16 only. The processing engines 16 process the request (step 116) and notify the gateway 
processor 12 (step 118) when processing is complete. The gateway processor 12 forwards that 
information to the controller processors 14 (step 120) and unlocks the path. The controller 
processor 14 then notifies the spooler processor 18 that processing is complete (step 122). 

15 During this processing several important decisions will be made by software. First, the 

gateway will analyze all methods known to it for solving the given client request. For each 
method, it will analyze the estimated time for completion. Each step, even to the addition of two 
simple integers, will be examined to determine the best course of action. When all known 
methods have been analyzed, the gateway processor will select the best and proceed with the 

20 operation. 

Each piece of the processing that is performed by the system is made to be atomic in 
nature, and in effect makes the entire task atomic; so that the entire task or any subtask can be 
made either completely successful or completely nonexistent, with any side effects from 
processing removed. 

25 Each process is broken down into "primitives 1 ' by the system, which are then compiled in a 

native machine language in the host machine's memory for execution. Once complete, this is 
termed a procedure, and this this procedure is built for reentrant and repeatable execution by 
multiple system processes and threads, allowing for more efficient use in high volume systems for 
repeat operations. 
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It is a function of the platform to allow each process as described to execute as if it was . 
the only process currently executing on the system. In order to do this, is necessary to avoid the 
effects of the wormhole theorem by providing a true linear timeline for each process to execute 
by. The distributed nature of the system makes this especially difficult to accomplish this. 
5 Therefore, a unique mechanism is used by the system to resolve these dependencies. As each 
process is started, it receives a timestamp of the start of its execution from the gateway that 
started it. Note that although the gateway times may not be exactly in synch with each other, it is 
not important that the process timeline be linear to any specific timeline, just that it be exactly 
linear in and of itself while arbitrating with other timelines (processes). This timestamp, then, 

10 becomes its linear reference. As the system arbitrates access between the processes for each piece 
of information, it utilizes this timestamp to evaluate its course of action. First, the type of action 
is considered. For example, a read only action will not create the same dependencies for other 
processes that a write operation will. To allow the greatest amount of parallelism therefore, each 
operation is "queued" against the data in the event of parallelism. If a read operation follows a 

15 write operation on the linear timeline, it is allowed to see the data the incomplete write operation 
will write, and can move on to complete its own task. A write operation following a read 
operation, appropriately, will not have its modification made until the formal completion of the 
read operation. Complications arise when, for whatever reason, a process that is ahead in the 
linear timeline of other processes is not able to complete, therefore invalidating assumptions made 

20 by the other processes queued on the data item. To resolve this, the system is able to reexecute 
each operation in the queue for the arbitrated item. Importantly, it is nearly always able to do this 
without any other arbitration or communications. It does this by storing a predicate, or truth 
evaluation, and transform, or change instructions for each operation that is queued. It is therefore 
able to recreate each process's access to the data without any awareness on behalf of the process, 

25 and with very little execution overhead. The actual granularity of the arbitration may be a file, 
page, tuple, attribute, range, or any other object designation. This combination of locking 
concepts is unique, and gives the system an extraordinary capacity to perform ACID operations 
with a very low transaction cross execution time. 

Continuing with the task being described, the spooler processor 1 8 requests output data 
30 from all of the processing engines 16 (step 124), formats the requested report based on the report 
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information forwarded to it by the gateway processor 12, and outputs the report to its associated 
output device (step 130). 

Referring now to Table 2 and FIG. 2, the data processing system of the present invention 
is shown servicing two simultaneous user application requests that require access to the same 
5 data. Operation for both requests is similar to that described above in connection with FIGS. 1 A 
and IB until the second gateway processor 12 recognizes that its access path has been locked by 
the first gateway processor. When that occurs, the second gateway processor 12 is prohibited 
from making its request until the processing engine 1 6 is done processing and the gateway 
processor 12 unlocks the path. The second gateway processor 12 is then free to make its request. 

10 Processor Implementation 

The processors of the present invention may be implemented as hardware devices, mixed 
hardware and software devices or software devices. For example, a gateway processor 12 may be 
implemented as: a custom Application Specific Integrated Circuit providing the proper 
functionality; a microprocessor programmed to function properly; or a software process running 

15 on a general purpose machine. Referring now to FIG. 1 , a processor of the present invention is 
shown implemented as a software device. FIG. 1 shows a parent process 40, which has spawned 
threaded child processes 42, 44, and 46. Threaded child processes 42 are the processes that 
actually carry out the work associated with a processor, whether the processor is a client 
processor 10, a gateway processor 12, a controller processor 14, a processing engine 16, or a 

20 spooler processor 18. Threaded process 44 is a statistics monitor. Threaded process 46 is a 
•'watchdog' 1 monitor. The child processes, shown generally as 42', do the work of the parent 
process 40. For example, a gateway processor 12 may have multiple client processors 10 making 
requests. For each client processor request, the gateway processor assigns a thread of execution, 
represented by child 42', which handles the set of steps associated with servicing that request. 

25 Child process 44' monitors statistics associated with the operation of the system. For 

example, child process 44' may track the number of requests made to a processing engine 1 6, the 
percent utilization of various processors, the percent utilization of a disk drive associated with its 
parent process, the number of messages being transferred over the network or bus, the number of 
transactions the system is currently executing, or the error rate of messages transmitted between 

30 processors. 
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Child process 46' is a "watchdog" monitor. Its function is to monitor outstanding requests 
that exceed the processor's time-out period. When this occurs, the watchdog monitor terminates 
the child process associated with the task and restarts the task. For example, if a gateway 
processor 12 has a child process 42' that is making a request of a processing engine 16 and the 
5 processing engine 16 is shut off in the middle of the request, child process 12' will exceed the 
time-out period of the gateway processor 42. When this happens, monitor 46* terminates the 
child process 42' responsible for executing the request. Thread process 42' recognizes that its 
child process 42' has been terminated, and notifies the monitor 46' that child process 42* has 
terminated. The monitor 46' then restores any system- wide tables or variables affected by the 
10 child process 42' and transmits a message to the system that the task being executed by the child 
process 42 1 has finished. Monitor 46' then spawns a new child process 42' to attempt the request 
again. 

Each child may in fact perform the work of any other child if so instructed, and this is an 
important feature of the system. The children themselves are "stateless robots", a term used in the 
invention to describe threads of execution that have no inherent memory or state of an operation. 
The children themselves, therefore, can be assigned at will to any given operation. This design 
allows a child to execute a process up until the point at which there will be a delay, such as a tuple 
retrieval from another node. At that point, it simply starts another task, or goes to work 
monitoring the incoming request queues. When a child receives a piece of information for a task, 
it also has the ability to immediately start executing that task should the received information 
allow for renewed processing. Any process memory that may be needed is stored with the task 
identification number, but often a task seems to simply take on a life of its own, moving from one 
node to the next in operation in a chained process as described earlier. This design is important 
because it facilitates the decomposition of single user requests into a number of parallelizable 
subtasks, and provides other benefits such as near zero wasted CPU cycles, since it is rare for a 
process to be waiting on any event. In the current embodiment of the system, the children are 
given specific instructions and grouped into functional objects manifested in the gateway 
processor, the controller processor, the spooler processor, and the processing engine. 

Additionally, certain fundamentals must be in place in order to facilitate the levels of 
parallelism achieved in the system. For example, there are no runtime data objects that are not 
scalable for arbitration. This requires certain unique data structures. For example, a fundamental 
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system construct is a set of free memory blocks. In a normal system, all processes would arbitrate 
to get the next free block. In a high traffic situation, this can bring a multiple CPU system to a 
crawl. The system resolves this by scaling the pool into a number of segments set to distribute 
arbitration. The same free pool is used, but the number of arbitration points is scaied so that the 
5 number of requests at each point no longer interferes with system throughput. Such fundamental 
structures are needed to provide true scalability throughout the system. 

Although only preferred embodiments are specifically illustrated and described herein, it 
will be appreciated that many other modifications and variations of the present invention are 
possible in light of the above teachings and within the preview of the appended claims without 
10 departing from the spirit and intended scope of the invention. Other objects, features and 

advantages of the invention shall become apparent when the following drawings, description and 
claims are considered. 
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What is claimed is: 

1 1 . A processing system comprising: 

2 a gateway processor; 

3 a controller processor in communication with said gateway processor; and 

4 a processing engine in communication with said gateway processor and said 

5 controller processor. 

1 2. The system of claim 1 further comprising a client processor in communication with said 

2 gateway processor. 

1 3 . The system of claim 1 further comprising a spooler processor in communication with said 

2 gateway processor, said controller processor, and said processing engine. 

1 4. The system of claim 3 wherein each of said spooler processor, said gateway processor, 

2 said controller processor, and said processing engine includes a statistics monitor. 

1 5. The system of claim 3 wherein each of said spooler processor, said gateway processor, 

2 said controller processor, and said processing engine includes a watchdog monitor. 

1 6. The system of claim 1 wherein said gateway processor, said controller processor, and said 

2 processing engine communicate by messages. 

1 7. The system of claim 1 wherein the processing engine is a database engine, 

1 8. The system of claim 1 wherein the processing engine is a computational engine. 

1 9, The system of claim 1 wherein said system resides in at least one memory element of only 

2 one host machine. 

1 1 0. The system of claim 1 wherein said system resides in at least one memory element of a 

2 plurality of host machines. 

1 11. The system of claim 10 wherein said plurality of host machines are networked. 
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1 12. A memory element containing the system of claim 1 wherein said memory element is 

2 selected from the group of: hard disk, floppy disk, CD-ROM, optical disk, and magnetic tape. 

1 13. A method for processing data comprising the steps of: 

2 providing at least one gateway processor; 

3 providing at least one controller processor; 

4 receiving a transaction from a client processor by a gateway process, 

5 distributing data from the at least one gateway processor to the at least one 

6 controller processor in response to the transaction. 

1 14. The method of claim 13 wherein said method further comprises the steps of transmitting a 

2 transaction to the gateway process by a client processor. 

1 15. The method of claim 1 3 further comprising the steps of: 

2 providing at least one processing engine; and 

3 distributing data from the at least one gateway processor to the at least one 

4 processing engine in response to the transaction. 

1 16. The method of claim 13 further comprising the steps of: 

2 providing at least one spooler processor; and 

3 distributing data from the at least one gateway processor to the at least one 

4 spooler processor in response to the transaction. 

1 17. A method for processing data comprising the steps of: 

2 providing at least one gateway processor; 

3 providing at least one controller processor; 

4 providing at least one processing engine; 

5 receiving a transaction from a client process with the at least one gateway 

6 processor; 

7 transmitting a session handle associated with the transaction from the at least one 

8 gateway processor to the client process; 

9 assigning a task identification number to the transaction; 
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10 transmitting information associated with the transaction from the al least one 

1 1 gateway processor to the at least one controller processor, wherein said information 

12 includes the task identification number, 

13 transmitting information associated with the transaction from the at least one 

14 gateway processor to the at least one processing engine; 

15 processing a plurality of data indicated by the transmitted information with the at 

16 least one processing engine; 

17 transmitting a signal indicating completion of said processing step from the at least 

18 one processing engines to the at least one gateway controller; and 

19 transmitting a signal indicating completion of said processing step from the at least 

20 one gateway processor to the at least one controller processor. 

1 1 8. The method of claim 17 further comprising the steps of: 

2 providing at least one spooler controller; 

3 transmitting information associated with the transaction from the at least one gateway 

4 processor to the at least one spooler controller, wherein the information includes the task 

5 identification number; 

6 requesting the processed information from the at least one processing engine by the at 

7 least one spooler controller; and 

8 transmitting the requested information from the at least one spooler controller to an 

9 output device. 

1 19. The method of claim 1 7 wherein said step of processing the information includes the step 

2 of locking out other accesses to a plurality of data indicated by the transmitted information. 

1 20. A processing system comprising: 

2 a processor having a process embodied therein wherein said process is selected from the 

3 group consisting of a gateway process, a controller process, a client process, a processing engine, 

4 and a spooler process, said process communicating with a gateway process, a controller process, 

5 a client process, a processing engine, and a spooler process. 
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